home *** CD-ROM | disk | FTP | other *** search
/ Cream of the Crop 1 / Cream of the Crop 1.iso / PROGRAM / DJLSR106.ARJ / STRPBRK.C < prev    next >
C/C++ Source or Header  |  1992-03-02  |  2KB  |  50 lines

  1. /* This is file STRPBRK.C */
  2. /* This file may have been modified by DJ Delorie (Jan 1991).  If so,
  3. ** these modifications are Coyright (C) 1991 DJ Delorie, 24 Kirsten Ave,
  4. ** Rochester NH, 03867-2954, USA.
  5. */
  6.  
  7. /*
  8.  * Copyright (c) 1985 Regents of the University of California.
  9.  * All rights reserved.
  10.  *
  11.  * Redistribution and use in source and binary forms are permitted
  12.  * provided that: (1) source distributions retain this entire copyright
  13.  * notice and comment, and (2) distributions including binaries display
  14.  * the following acknowledgement:  ``This product includes software
  15.  * developed by the University of California, Berkeley and its contributors''
  16.  * in the documentation or other materials provided with the distribution
  17.  * and in all advertising materials mentioning features or use of this
  18.  * software. Neither the name of the University nor the names of its
  19.  * contributors may be used to endorse or promote products derived
  20.  * from this software without specific prior written permission.
  21.  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR
  22.  * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
  23.  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
  24.  */
  25.  
  26. #if defined(LIBC_SCCS) && !defined(lint)
  27. static char sccsid[] = "@(#)strpbrk.c    5.7 (Berkeley) 6/1/90";
  28. #endif /* LIBC_SCCS and not lint */
  29.  
  30. #include <string.h>
  31. #include <sys/stdc.h>
  32.  
  33. /*
  34.  * Find the first occurrence in s1 of a character in s2 (excluding NUL).
  35.  */
  36. char *
  37. strpbrk(s1, s2)
  38.     register const char *s1, *s2;
  39. {
  40.     register const char *scanp;
  41.     register int c, sc;
  42.  
  43.     while ((c = *s1++) != 0) {
  44.         for (scanp = s2; (sc = *scanp++) != 0;)
  45.             if (sc == c)
  46.                 return ((char *)(s1 - 1));
  47.     }
  48.     return (NULL);
  49. }
  50.